<template>
  <div class="md-mixed-key-board">
    <div
      v-for="(item, index) in mixedKeyboard"
      :key="index"
      class="md-mixed-key-board-item"
      :class="{disabled: item.disabled}"
    >
      <template v-if="item.type">
        <div
          :class="item.type"
          v-tap="{
            methods:
              item.type === 'delete' ? $_onDelete : $_onConfirm,
            disabled: item.disabled
          }"
        >
          <div v-if="item.type === 'confirm' && item.text">{{ item.text }}</div>
        </div>
      </template>
      <template v-else>
        <div
          v-tap="{
            methods: $_onEnter,
            disabled: item.disabled
          }"
        >{{ item.value }}</div>
      </template>
    </div>
  </div>
</template>

<script>export default {
  name: 'md-mixed-key-board',

  components: {},

  props: {
    // 混合键盘数据
    mixedKeyboard: {
      type: Array,
      default: () => {
        return []
      },
    },
  },

  data() {
    return {}
  },

  methods: {
    $_onEnter(value) {
      this.$emit('enter', value)
    },
    $_onDelete() {
      this.$emit('delete')
    },
    $_onConfirm() {
      this.$emit('confirm')
    },
  },
}
</script>

<style lang="stylus">
.md-mixed-key-board {
  padding: 32px 0px;
  display: flex;
  flex-wrap: wrap;
  .md-mixed-key-board-item {
    >div{
      display: flex;
      align-items: center;
      justify-content: center;
      width: 64px;
      height: 104px;
      background: #FFFFFF;
      box-shadow: 0px 2px 0px 0px rgba(159,159,159,0.5);
      border-radius: 10px;
      font-family: font-family-normal;
      font-size: 40px;
      color: #111A34;
      font-weight: 400;
      margin: 0px 0px 10px 10px;
      &.delete{
        background: url(../_style/images/license-keyboard-del.png) center no-repeat;
        background-color: #FFFFFF;
        background-size: 40px 40px;
      }
      &.confirm{
        width: 212px;
        background: #198CFF;
        box-shadow: none;
        font-size: 36px;
        color: #FFFFFF;
      }
    }
    &.disabled{
      >div{
        background: #F5F5F5;
        color: #C1C8CF;
      }
    }
  }
}
</style>
